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Title: HIGH SPEED SOFTWARE DRIVEN EMULATOR COMPRISED OF A 
PLURALITY OF EMULATION PROCESSORS WITH A METHOD TO 
ALLOW MEMORY READ/WRITES WITHOUT INTERRUPTING THE 
EMULATION 

5 Cross Reference to Related Applications: 

The following copending applications, assigned to the assignee of 
the present invention;, contain common disclosure and are 
incorporated herein by reference in their entireties: 

"High Speed Software Driven Emulator Comprised of a Plurality of 
10 Emulation Processors with Improved Board-to-Board Interconnection 

Cable Length Identification System/' Serial No. , filed 

, (Attorney Docket No. POU9-2000-0045-US1) . 

''High Speed Software Driven Emulator Comprised of a Plurality of 
Emulation Processors with an Improved Maintenance Bus that 

15 Streams Data at High Speed/' Serial No, ^ filed 

, (Attorney Docket No. POU9-2000-0046-US1) . 

'"High Speed Software Driven Emulator Comprised of a Plurality of 
Emulation Processors with a Method to Allow High Speed Bulk 
Read/Write Operation Synchronous DRAM While Refreshing the 

20 Memory/' Serial No. , filed , (Attorney Docket 

No. POU9-2000-0047-US1) . 

''High Speed Software Driven Emulator Comprised of a Plurality of 
Emulation Processors with Improved Multiplexed Data Memory/' 

Serial No. , filed , (Attorney Docket No. 

25 POU9-1999-0183-US1) 
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Field of the Invention: 

This invention relates to software driven emulators in which a 
large number of processors operate in parallel to emulate complex 
logical functions, and more particularly, to a system and method 
5 for managing the memory arrays of such emulators so that memory 
data transfers can be executed without interrupting the emulation 
process . 

Trademarks : 

S/390 and IBM are registered trademarks of International Business 
10 Machines Corporation, Armonk, New York, U.S.A. and Lotus is a 
registered trademark of its subsidiary Lotus Development 
Corporation, an independent subsidiary of International Business 
Machines Corporation, Armonk, NY. Other names may be registered 
trademarks or product names of International Business Machines 
15 Corporation or other companies. 

Background: 

The usefulness of software driven emulators has increased 
enormously with growth in the complexity of integrated circuits. 
Basically, an emulation engine operates to mimic the logical 

20 design of a set of one or more integrated circuit chips. The 
emulation of these chips in terms of their logical design is 
highly desirable for several reasons. The utilization of 
emulation engines has also grown up with and around the 
corresponding utilization of design automation tools for the 

25 construction and design of integrated circuit chip devices. In 
particular, as part of the input for the design automation 
process, logic descriptions of the desired circuit chip functions 
are provided. The existence of such software tools for 
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processing these descriptions in the design process is well 
suited to the utilization of emulation engines which are 
electrically configured to duplicate the same logic function that 
is provided by a design automation tool. 

5 Utilization of emulation devices permits testing and verification 
via electrical circuits of logic designs before these designs are 
committed to a socalled "silicon foundry" for manufacture. The 
input to such foundries is the functional logic description 
required for the chip and its output is initially a set of 
10 photolithographic masks which are then used in the manufacture of 
the desired electrical circuit chip device. Verifying that logic 
designs are correct in the early stage of chip manufacturing 
eliminates the need for costly and time-consuming second passes 
through a silicon foundry. 

15 Another advantage of emulation systems is that they provide a 
device that makes possible the early validation of software meant 
to operate the emulated chips. Thus, software can be designed, 
evaluated and tested well before the time when actual circuit 
chips become available. Additionally, emulation systems can also 

20 operate as simulator-accelerator devices thus providing a 
high-speed simulation platform. 

Emulation engines of the type contemplated by this invention 
contain an interconnected array of emulation processors (EP) . 
Each emulation processor (hereinafter also sometimes simply 

25 referred to as "processor") can be programmed to evaluate logic 
functions (for example, AND, OR, XOR, NOT, NOR, NAND, etc.). The 
program driven processors operate together as an interconnected 
unit, emulate the entire desired logic design. However, as 
integrated circuit designs grow in size, more emulation 

30 processors are required to accomplish the emulation task. An aim. 
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therefore^ is to increase the capacity of emulation engines in 
order to meet the increasingly difficult task of emulating more 
and more complex circuits and logic functions by increasing the 
number of emulation processors in each of its modules. 

5 For purposes of better understanding the structure and operation 
of emulation devices generally, and this invention particularly, 
United States Patent No. 5,551,013 and patent application Serial 
No. 09/373,125 filed August 12, 1999, both of which are assigned 
to the assignee of this application, are hereby incorporated 
10 herein by reference. 

Patent No. 5,551,013 shows an emulation chip, called a module 
here, having multiple (e.g. 64) processors. All processors 
within the module are identical. The sequencer and the 
interconnection network occur only once in a module. The control 

15 stores hold a program created by an emulation compiler for a 
specified processor. The stacks hold data and inputs previously 
generated and are addressed by fields in a corresponding control 
word to locate the bits for input to the logic element. During 
each step of the sequencer an emulation processor emulates a 

20 logic function according to the emulation program. The data flow 
control interprets the current control word to route and latch 
data within the processor. The node-bit-out signal from a 
specified processor is presented to the interconnection network 
where it is distributed to each of the multiplexers (one for each 

25 processor) of the module. The node address field in the control 
word allows a specified processor to select for its node-bit-in 
signal the node-bit-out signal from any of the processors within 
its module. The node bit is stored in the input stack on every 
step. During any operation, the node-bit-out signal of a 

30 specified processor may be accessed by none, one, or all of the 
processors within the module. 
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Data routing within each processor' s data flow and through the 
interconnection network occurs independently of and overlaps the 
execution of the logic emulation function in each processor. 
Each control store stores control words executed sequentially 
5 under control of the sequencer and program steps in the 
associated module. Each revolution of the sequencer causes the 
step value to advance from zero to a predetermined maximum value 
and corresponds to one target clock cycle for the emulated 
design. A control word in the control store is simultaneously 
10 selected during each step of the sequencer. A logic function 
operation is defined by each control word. 

Each of these emulation processors has an execution unit for 
processing multiple types of logic gate functions. Each 
emulation processor switches from a specified one logic gate 

15 function to a next logic gate function in a switched-emulation 
sequence of different gate functions. The switched-emulation 
sequence of each of the processors thus can emulate a subset of 
gates in a hardware arrangement in which gates are of any type 
that the emulation processors functionally represent for a 

20 sequence of clock cycles. The processors are coupled by a like 
number of multiplexers having outputs respectively connected to 
the emulation processors of a module and having inputs 
respectively connected to each of the other emulation processors. 
The bus connected to the multiplexers enables an output from any 

25 emulation processor to be transferred to an input of any other of 
the emulation processors. In accordance with the teachings of 
the pending application, the basic design of the 5,551,013 patent 
is improved by interconnecting processors into clusters. With the 
processors cascaded, all processors in a cluster perform the 

30 setup and storing of results in parallel. This setup includes 
routing of the data through multiple evaluation units for the 
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evaluation phase. For most efficient operation^ the input stack 
and data stack of each processor must be stored in shared memory 
within each cluster. Then, all processors perform the storage 
phase;, again in parallel. The net result is multiple cascaded 
5 evaluations performed in a single emulation step. Every 
processor in a cluster can access the input and data stacks of 
every other processor in the cluster and less space on each 
module chip for the functions that support the processor 
operation, particularly the memory functions. 

10 The ET4 emulator can be partitioned so that the emulator is 
capable of running more than one emulation at a time. To fully 
exploit this capability, there is a need to read from and write 
to the "main data memories". Each module has a main data memory, 
comprised of two commercially available Sync DRAMs and one 

15 commercially available SSRAM. Each emulator board is comprised 
of sixty-five modules and a memory controller serves all modules 
on a board. In prior art emulators of the type contemplated by 
this invention, an emulation process is stopped in order to read 
or write data to a main module memory from a source external to 

20 the emulation process. 

Summary of the Invention: 

An object of this invention is the provision of a method that 
enables transfers of external data to and from a module's main 
data memories without interrupting emulation in progress. 

25 Briefly, this invention contemplates the provision of a software 
driven emulator in which the stored emulation program for a 
processor module is compiled to include a code bit or bits in the 
emulation instruction step sequence that is decoded as main data 
memory disable command. Thus, once in each emulation program 
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cycle^ the memory controller disables the main data memories on 
the module, and allows the maintenance bus to read or write data 
to these memories. 

Brief Description of the Drawings: 

5 The foregoing and other features and advantages of the invention 
will be described with reference to the accompanying drawings. 
In the drawings, like reference numbers generally indicate 
identical, functionally similar, and/or structurally similar 
elements. Also in the figures, the left most digit of each 
10 reference number corresponds to the figure in which the reference 
number is first used. 

Figure 1 is a high level block diagram of two of the modules on a 
printed circuit board of the type to which this invention is 
applicable . 

15 Figure 2 is a logic block diagram illustrating the system for 
reading and/or writing to the main module memories without 
interrupting the emulation process in accordance with the 
teachings of this invention. 

Detailed Description of the Invention: 

20 Referring now to Figure 1, an emulator of the type contemplated 
by this invention is comprised of a number of printed circuit 
boards 14 interconnected by a maintenance bus, which also 
connects each board to a work station 26. Work station 26 
serves, among other functions, to load data to the emulator 

25 memories, and receive data from the emulator memories. Each 
printed circuit board has a memory controller 22, which provides 
a memory control interface function for the modules on a printed 
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circuit board- Each module (only two are illustrated in Figure 1) 
includes a processor chip 16 (ET4) and three RAM chips 18 (two 
SDRAMs and one SSRAM) , which are coupled to the ET4 processor 16. 
Each ET4 chip is comprised of sixty-four one-bit processors. 

5 Referring now to Figure 2 as well the preceding figure^, each of 
the 64 processors in the module includes a control store 30^ 
which in this illustrative embodiment is 256 steps deep with 96 
bits wide processor control codes that determine the logic 
function of the associated processor 31 during that step in the 

10 emulation process. As will be appreciated by those skilled in the 
art, in carrying out an emulation, a compiler program compiles 
the logic design as a series of processor instruction steps that 
are stored in the control store 30 of each processor in a module. 
In accordance with the teaching of this invention, in order to 

15 allow reading and/or writing to the RAM memories of a module, the 
control store program in one of the control store memories is 
compiled so that it has a bit in a bit location that is decoded 
as command to memory controller 22 to disable all module 
processors from writing to or reading from the module RAM 

20 memories 18. As illustrated in Figure 2, bit "M" in step ^'N" is 
set to a predetermined binary value (""^O'' or 1" ) f decoder 33 
decodes the state of bit "'M'' in step "'N" and sends a disable 
command to memory controller over the maintenance bus. This 
allows work station 22 to transfer data to or from the module'' s 

25 RAM memories during this step in each cycle of control store 30. 
When the program progresses to the next step, the disable command 
terminates and the processors are again enabled for data transfer 
to and from the RAMs . Of course, the program could be compiled 
and decoded to provide two or more interrupts each cycle of the 

30 control store. 
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While the preferred embodiment to the invention has been 
described, it will be understood that those skilled in the art, 
both now and in the future, may make various improvements and 
enhancements which fall within the scope of the claims which 
5 follow. These claims should be construed to maintain the proper 
protection for the invention first described. 
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What is claimed is: 

1 Claim 1. In an emulation engine comprised of a plurality of 

2 modules, a work station, and a maintenance bus for 

3 transferring data between the work station and said modules, 

4 each of said modules including a plurality of module 

5 processors and a module main memory unit accessible for data 

6 transfers during an emulation by each of said plurality of 

7 processors, each of said processors having a control store 

8 to store a programmable sequence of emulation steps that 

9 define logic states for its processor, a method to allow 

10 data transfers between said module main memory unit and said 

11 work station without interrupting an in progress emulation, 

12 including the steps of: 

13 compiling said programmable sequence of emulation steps 

14 to include, in at least one step, a blocking code that is 

15 decoded, when the step is read from the control store, as a 

16 disable command between the plurality of module processors 

17 and said module main memory; 

18 decoding said blocking code and, in response thereto, 

19 blocking transfers between the plurality of module 

20 processors and said module main memory; and 

21 transferring data between said work station and said 

22 module main memory while transfers between the plurality of 

23 module processors and said module main memory are blocked. 

1 Claim 2. A method to allow data transfers between said 

2 module main memory unit and said work station as in claim 1 

3 further including the step of unblocking transfers between 

4 the plurality of module processors and said module main 

5 memory when the step is decoded that is next in the sequence 

6 after said step that includes said blocking code. 
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1 Claim 3. A method to allow data transfers between said 

2 module main memory unit and said work station as in claim 1 

3 wherein said programmable sequence is repeated and said 

4 decoding and transferring steps are repeated with each 

5 repetition of said programmable sequence, 

1 Claim 4, A method to allow data transfers between said 

2 module main memory unit and said work station as in claim 2 

3 wherein said programmable sequence is repeated and said 

4 decoding and transferring steps are repeated with each 

5 repetition of said programmable sequence. 
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Title: HIGH SPEED SOFTWARE DRIVEN EMULATOR COMPRISED OF A 
PLURALITY OF EMULATION PROCESSORS WITH A METHOD TO 
ALLOW MEMORY READ/WRITES WITHOUT INTERRUPTING THE 
EMULATION 



5 Abstract of the Disclosure: 

A software driven emulator in which the stored emulation program 
for a processor module is compiled to include a code bit or bits 
in the emulation instruction step sequence that is decoded as 
main data memory disable command. Thus, once in each emulation 
10 program cycle, the memory controller disables the main data 
memories on the module, and allows the maintenance bus to read or 
write data to these memories. 
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